### Simulador RISC-V

Por: Guilherme Da Hora Andrade Fontoura, Amanda Lemos Ribas, Maria Eduarda D'Angelo Quitete Vianna, Lais Ferreira Nazareth

### Resumo

O projeto consiste em um Simulador/Assembler da arquitetura RISC-V com implementação de pipeline.

Ele é capaz de receber um arquivo .txt (código binário gerado pelo RARS) ou .asm e executá-lo, mostrando as instruções em seus respectivos estágios no pipeline em uma interface gráfica.

### Funcionalidades

- Receber arquivo .asm ou .txt e executar as instruções
- Implementação de pipeline
- Tratamento de hazards
- Interface gráfica que permite analisar a execução do arquivo "step by step"

## Tecnologias Usadas



### Estrutura de Diretório



**Assembler Risc-V** 



arquivosexemplos



interface



pipeline

InstructionFetch.py InstructionDecode.py Execute.py

MemoryAccess.py

WriteBack.py

RunPipeline.py

DeteeccaoHazards.py



riscv\_data

registers.py instructions.py

main.py

Instruction Fetch (para .asm)

- Quebra a instrução com split
- Usa o mnemônico para buscar informações da instrução em instructions.py
- Define rd, rs1, rs2 e immediate dependendo do tipo da instrução e mnemônico

Instruction Fetch (para.txt)

- Busca opcode para determinar tipo
- Analisa funct3 e funct7 para determinar instrução
- Lê rd, rs1, rs2 e immediate

# Implementação Pipeline Instruction Decode

- Recebe a instrução do Instruction Fetch
- Analisa o tipo da instrução
- Busca registradores utilizados no banco de registradores
- Caso use imediato, carrega valor para o campo correto

#### **Execute**

- Recebe lista contendo dados da instrução e dos registradores de Instruction Decode
- Executa a instrução
- Retorna lista com tipo da instrução, mnemônico, address(rd) e operandos da instrução

#### **Memory Access**

- Recebe lista do Execute
- Se for lw, retorna o valor que está na posição da memória
- Se for sw, salva o valor de rd na posição da memória

# Implementação Pipeline Write Back

- Guarda o sinal de controle memToReg
- Verifica o tipo da instrução e, se for válido, guarda o valor a escrever no registrador de destino

## Registradores e Instruções

- São armazenados na pasta riscv\_data
- Classe registradores e classe instruções
- Dicionários para cada classe contendo valores dos registradores e informações das instruções

## Detecção de Hazards

 Procura identificar hazards para fazer o tratamento posteriormente, entretanto não foi possível concluir a implementação. O rascunho da implementação pode ser encontrado em DeteccaoHazards.py

### Interface



### Interface



## Obrigado!